# **Operating Systems**

# **Virtual Memory Simulator**

## Introduction:

Implementation of a virtual memory simulator. This simulator consists of several important parts: the <u>CPU</u> which contains the <u>memory management unit</u> and the <u>TLB cache</u>, <u>the virtual page table</u>, <u>physical memory</u>, and the <u>operating system</u>. This system must be modular, that is, the aforementioned parts must be represented by at least one class each.

### Implementation:

Data Structures:

You must use <u>fixed-size arrays</u> to simulate the page table, the TLB, the page, and physical memory.

- Physical memory will be a two-dimensional array to simulate the page-frame # and the page of
  byte-addressable, byte-sized data. For instance, if physical memory can hold 16 pages of data and each page
  is 1kB, then you would have a 2d array like: ram[16][1024]. Read further to determine what values you must
  use in your simulator. In each byte of ram you will store an integer value (yes, an int is typically larger than a
  byte but this will make the project simpler).
- The page table will be an array of PageTableEntries (so the page table will be a one-dimensional array). You will use the virtual page number (V-Page#) as the index to the elements of this array.

Table entry for the virtual page table:

| V | R | D | PageFrame# |  |  |
|---|---|---|------------|--|--|

• The TLB will be a one-dimensional array of TlbEntries. A TlbEntry consists of a virtual page number and a frame number. The TLB is small and must be scanned on every lookup. The arrays used to implement the page table and TLB will be arrays of data structures that represent the tables' entries.

Table entry for the TLB:

| <u> </u> |   |   |   |            |
|----------|---|---|---|------------|
| V-Page#  | V | R | D | PageFrame# |

### Data Files:

The test files and page files will simulate the various reads and writes to addresses by a running process (test files), and the process' pages of data that the OS must load from the hard drive and put into memory. If a write to memory occurs and the OS needs to evict the dirty page, then the OS must write the page back to the file on the hard disk.

The test file format is:

0

1C85

1

A1B5

8517174

. . .

Where the first value represents whether it is a read (0) or write (1), The second value is the address to be read from or written to. If the action is a write (1) then there will be a third value which represents the integer to be written to memory.

The page files hold the data elements from the processes virtual memory.

# The Simulated Computer:

- The CPU address width is 16 bits
- Physical memory's address width is 12 bits
- The page offset is 8 bits.
- The TLB contains 8 entries.
- The OS uses the clock algorithm for page replacement
- The MMU uses FIFO for replacement algorithm
- The OS resets the r-bit every 20 instructions.

Note: you are not permitted to use any containers or data structures provided by your chosen language other than simple arrays (i.e., no arraylists). You must implement the clock replacement algorithm's data structure as a circular linked list.

#### Execution:

Your program will accept as a <u>command line argument the test file path to a text file populated with virtual memory addresses</u> (in hex and also provided with this project) that are used to simulate memory accesses called by a process. Your CPU will read them, hand them to the MMU for fetching or writing. If the address is preceded by a zero, then the MMU should only read and output the value. If the address is preceded by a one, then the address will be followed by a decimal value that needs to be written to physical memory. In the latter case, the page containing the data must have it's dirty bit set by the MMU in both the TLB and the page table. This page must be written back to disk if your page replacement algorithm decides to replace the file.

For each test file that you run, you should <u>use an original copy</u> of the page files that are available with the project. You do not want altered page files of a previous run to be used. Keep the originals in a safe place and overwrite the working set for each simulation. This should be done programmatically from within your simulator, not manually. You should use a file copy facility of your chosen language, not an operating system call. You cannot assume that the operating system of the grader is the same as yours.

The page files hold the simulated data of the process' virtual memory. Each filename is titled with the page number that it represents.

#### Output:

Your program will output the following information in a CSV file (with appropriate headers):

The address, Read or write (0 or 1), The value read or written, Soft miss (0 = false, 1 = true), Hard miss (0 = false, 1 = true), A hit (0 = false, 1 = true), page number of the evicted page, was that page's dirty bit set.

The header of the CSV should be:

Address, r/w, value, soft, hard, hit, evicted pg#, dirty evicted page

There should be one csv for every test file.

## More on Page Replacement:

We will keep the page replacement algorithm simple. Please implement the clock algorithm for page replacement. When a hard miss occurs, it's the job of the OS to replace the page and write the evicted page back to the drive if the dirty bit is set. The CPU should trap to the OS when hard misses occur.

The MMU is responsible to set the r-bit and the d-bit; the OS is responsible for unsetting them. The MMU should set the r-bit on a read or write of data in both the TLB and the page table. It should set the dirty bit on a write. The OS should unset the r-bits of all table entries after the CPU processes twenty instructions; it should reset the d-bit after a page has been written back to the disk.

When the MMU encounters a soft or hard miss it will need to overwrite a record in the TLB with the entry of the page being called for. You can use the FIFO replacement algorithm for this. The MMU should also set the r-bit in the page table when it needs to access it on a lookup.